<script setup lang="ts">
import KnowledgeCard from './KnowledgeCard.vue'
import { ref } from 'vue'
import type { KnowledgeType, KnowledgeList, KnowledgeParams } from '@/types/consult'
import { getKnowledgePage } from '@/services/consult'
/* 下拉加载更多 */
const props = defineProps<{
    type: KnowledgeType
}>()

const loading = ref(false)
const finished = ref(false)
const list = ref<KnowledgeList>([])
const params = ref<KnowledgeParams>({
    type: props.type,
    current: 1,
    pageSize: 10
})
const onLoad = async () => {
    // 加载数据
   const res = await getKnowledgePage(params.value)
   list.value.push(...res.data.rows)
   // 是否加载完毕
   if (params.value.current >= res.data.pageTotal) {
    finished.value = true
   } else {
    params.value.current++
   }
   loading.value = false
}
</script>

<template>
  <div class="knowledge-list">
    <van-list
  v-model:loading="loading"
  :finished="finished"
  finished-text="没有更多了"
  @load="onLoad"
>
<knowledge-card v-for="item in list" :key="item.id" :item="item"></knowledge-card>
</van-list>
    
  </div>
</template>

<style lang="scss" scoped>
.knowledge-list {
  padding: 0 15px;
}
</style>
